package com.mmc.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.mmc.entity.Role;
import com.mmc.entity.User;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * 用户角色关联数据访问层
 *
 * @author kunfe
 * @since 2024-01-01
 */
@Mapper
public interface UserRoleMapper extends BaseMapper<Object> {

    /**
     * 根据用户ID删除角色关联
     */
    int deleteByUserId(@Param("userId") Long userId);

    /**
     * 批量删除用户角色关联
     */
    int batchDeleteByUserIds(@Param("userIds") List<Long> userIds);

    /**
     * 批量插入用户角色关联
     */
    int batchInsert(@Param("userId") Long userId, @Param("roleIds") List<Long> roleIds);

    /**
     * 根据用户ID查询角色ID列表
     */
    List<Long> selectRoleIdsByUserId(@Param("userId") Long userId);

    /**
     * 根据用户ID查询角色列表
     */
    List<Role> selectRolesByUserId(@Param("userId") Long userId);

    /**
     * 根据角色ID查询用户列表
     */
    List<User> selectUsersByRoleId(@Param("roleId") Long roleId);

    /**
     * 根据角色ID查询用户ID列表
     */
    List<Long> selectUserIdsByRoleId(@Param("roleId") Long roleId);

    /**
     * 根据角色ID删除用户关联
     */
    int deleteByRoleId(@Param("roleId") Long roleId);
} 